Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Several performance optimizations #100

Open
wants to merge 4 commits into
base: develop
Choose a base branch
from
Open

Conversation

kdavyd
Copy link

@kdavyd kdavyd commented Aug 31, 2021

About 4.5x overall increase in download throughput. Most of this is by switching to release build, but other optimizations got a combined ~1.5x increase too, as tested on m6i.8xlarge instances with EBS VPC Endpoint.

Focusing on download performance only. Best performance I got is around 230MB/sec on a fully allocated 100GB snapshot.

Issue #, if available:

Description of changes:

  • Used release build.
  • Fat LTO enabled.
  • Allocate 520KB buffer for each request. (512KB + overhead, 8KB-aligned)
  • Tweaked Tokyo thread settings.
  • Increased worker threads to match Tokyo.
  • Added more retries.

By submitting this pull request, I confirm that you can use, modify, copy, and redistribute this contribution, under the terms of your choice.

…nload throughput. Most of this is by switching to release build, but other optimizations got a combined ~1.5x increase too, as tested on m6i.8xlarge instances with EBS VPC Endpoint.
@tjkirch tjkirch requested a review from bcressey September 1, 2021 00:13
@jpculp
Copy link
Contributor

jpculp commented Sep 3, 2021

Thanks for this, @kdavyd! We're giving it a look!

Copy link
Contributor

@zmrow zmrow left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the contribution!

const SHA256_ALGORITHM: &str = "SHA256";
const DISABLE_SHA: bool = true;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We probably don't want to turn off the SHA hash checking by default. I could maybe see providing users a flag to turn this off, but a constant isn't really configurable, and isn't currently documented or particularly discoverable.

@@ -355,7 +358,9 @@ impl SnapshotDownloader {
.await
.context(error::WriteFileBytes { path, count })?;

f.flush().await.context(error::FlushFile { path })?;
if !DISABLE_SHA {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The formatting looks a bit off here - can we make sure to run all the code through rustfmt?

type Result<T> = std::result::Result<T, error::Error>;

#[tokio::main]
#[tokio::main(flavor = "multi_thread", worker_threads = 512)]
Copy link
Contributor

@zmrow zmrow Sep 14, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Curious how you calculated or determined this number!

rusoto-native-tls = ["rusoto_core/native-tls", "rusoto_ebs/native-tls", "rusoto_ec2/native-tls"]
rusoto-rustls = ["rusoto_core/rustls", "rusoto_ebs/rustls", "rusoto_ec2/rustls"]

[dependencies]
argh = "0.1.3"
tokio = { version = "~1.8", features = ["fs", "io-util", "time"] } # LTS
tokio = { version = "~1.11", features = ["fs", "io-util", "time"] } # LTS
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also, we're hoping to stay on tokio 1.8 as it's an LTS release.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants